// Licensed to the LF AI & Data foundation under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The ASF licenses this file
// to you under the Apache License, Version 2.0 (the
// "License"); you may not use this file except in compliance
// with the License. You may obtain a copy of the License at
//
//     http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

package datacoord

import (
	"context"

	"google.golang.org/protobuf/proto"

	"github.com/milvus-io/milvus/internal/datacoord/task"
	"github.com/milvus-io/milvus/pkg/v2/proto/indexpb"
)

type analyzeInspector struct {
	mt *meta

	scheduler task.GlobalScheduler
}

func newAnalyzeInspector(ctx context.Context,
	mt *meta,
	scheduler task.GlobalScheduler,
) *analyzeInspector {
	return &analyzeInspector{
		mt:        mt,
		scheduler: scheduler,
	}
}

func (ai *analyzeInspector) Start() {
	ai.reloadFromMeta()
}

func (ai *analyzeInspector) Stop() {
}

func (ai *analyzeInspector) reloadFromMeta() {
	analyzeTasks := ai.mt.analyzeMeta.GetAllTasks()
	for _, t := range analyzeTasks {
		if t.GetState() != indexpb.JobState_JobStateInit &&
			t.GetState() != indexpb.JobState_JobStateRetry &&
			t.GetState() != indexpb.JobState_JobStateInProgress {
			continue
		}
		ai.scheduler.Enqueue(newAnalyzeTask(
			proto.Clone(t).(*indexpb.AnalyzeTask),
			ai.mt,
		))
	}
}
